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APPARATUS AND METHOD FOR EXTRACTING 
DATA VALUES FROM A SIGNAL ENCODED WITH 
AES3 DATA 

Background of the Invention 
[0001] This invention relates to an apparatus and method 
for extracting data values from a signal encoded with AES3 
data . 

[0002] The Audio Engineering Society and the European 

Broadcasting Union have established a standard which 
describes a signal format for distributing two channels of 
audio material in a digital data stream. The data stream, 
which is frequently referred to as the AES3 data stream, is 
composed of frames, and each frame of the AES3 data stream is 
composed of two channel subframes, which are referred to as 
subframe A and subframe B, in sequence. The data stream 
utilizes a biphase mar]<: coded signal. Each source data bit 
is represented by a two-cell doublet. Each doublet that 
represents a source data bit begins, and therefore also ends, 
with a transition. A source data bit 0 generates a doublet 
with no further transition before the end of the doublet, 
whereas a source data bit 1 generates a transition between 
the cells of the doublet. Thus, a source data bit 1 will be 
represented by the doublet 01 or 10 and a source data bit 0 
will be represented by the doublet 00 or 11. Each subframe 
has 32 doublets and contains data representing one audio 
sample. In accordance with the AES3 standard, the first four 
doublets of each subframe constitute a preamble containing at 
least one occurrence of the three cell sequence 000 or 111. 
This brief departure from the usual biphase mark coding rules 
is known as a code violation. 

[0003] It will be appreciated from the foregoing that a 
signal encoded with an AES3 data stream is composed of 
pulses, and each pulse is one, two or three bit cells in 
duration. In the following description, a pulse that is one 
bit cell in duration is referred to as a half pulse, a pulse 
that is two bit cells in duration is referred to as a whole 
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pulse, and a pulse that is three bit cells in duration is 
referred to as a wide pulse. 

[0004] The AES3 standard does not prescribe a sample rate 
and accordingly in a given facility there may be items of 
equipment operating at different sample rates, such as 44.1 
kHz, 48 kHz and 96 kHz. Hitherto, in order to extract the 
data from an AES3 data stream, it has been necessary to 
recover the clock information from the data stream and use 
the recovered clock to sample the signal. This approach is 
not optimum because a circuit that is designed for extracting 
data from a data stream at a sample rate of 44.1 kHz might 
not be able to extract data reliably from a data stream at a 
sample rate of 96 kHz. 

Summary of the Invention 
[0005] In accordance with a first aspect of the invention 
there is provided apparatus for determining nominal pulse 
duration values in a signal encoded with an AES3 data stream, 
comprising a first circuit for measuring duration of each 
pulse of the signal and providing a sequence of duration 
values, and a second circuit for detecting a maximum duration 
value, corresponding to duration of three bit cells, and 
providing first and second duration values corresponding to 
one bit cell and two bit cells respectively. 

[0006] In accordance with a second aspect of the invention 
there is provided apparatus for extracting sample data values 
from a signal encoded with an AES3 data stream, comprising a 
first circuit for measuring duration of each pulse of the 
signal and providing a sequence of duration values, and a 
second circuit for receiving at least one nominal pulse 
duration value, corresponding to nominal duration of a 
predetermined number of bit cells, and comparing the measured 
duration value with at least one nominal pulse duration value 
to determine the duration of the pulse relative to the 
nominal pulse duration value. 

[0007] In accordance with a third aspect of the invention 
there is provided a method for determining nominal pulse 
duration values in a signal encoded with an AES3 data stream. 
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comprising measuring duration of each pulse of the signal and 
providing a sequence of duration values, and detecting a 
maximum duration value, corresponding to duration of three 
bit cells, and providing first and second duration values 
corresponding to one bit cell and two bit cells respectively. 
[0008 In accordance with a fourth aspect of the invention 

there is provided a method for extracting sample data values 
from a signal encoded with an AES3 data stream, comprising 
measuring duration of each pulse of the signal and providing 
a sequence of duration values, receiving at least one nominal 
pulse duration value, corresponding to nominal duration of a 
predetermined number of bit cells, and comparing the measured 
duration value with at least one nominal pulse duration value 
to determine the duration of the pulse relative to the 
nominal pulse duration value. 

Brief Description of the Drawings 
[0009] For a better understanding of the invention, and to 
show how the same may be carried into effect, reference will 
now be made, by way of example, to the accompanying drawings, 
the single Figure of which is a schematic block diagram of 
apparatus in accordance with the invention. 

Detailed Description 
[00010] The apparatus illustrated in the drawings includes 
an edge detector 10 which receives an input signal encoded 
with an AES3 data stream at its input and receives a 
reference clock signal having a frequency several times the 
maximum sample rate of the input signal at its clock input. 
For example, if the apparatus were used in a facility in 
which the maximum sample rate of the AES3 data stream was 96 
kHz, the reference clock signal might have a frequency of 100 
MHz. The edge detector 10 is of conventional topology and 
provides an output pulse in response to each edge (rising and 
falling) of the input signal. The duration of the output 
pulse is less than the duration of a half pulse of the input 
signal . 
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[00011] The output signal of the edge detector is provided 
to the reset input of a counter 14 which also receives the 
reference clock signal at its clock input. In response to 
each output pulse of the edge detector, the counter is reset 
to zero and starts counting. The counter provides a digital 
output signal reflecting the count value attained prior to 
the previous reset. Thus, the edge detector 10 and the 
counter 14 measure the length of each pulse (positive going 
and negative going) of the input signal with a resolution of 
10 ns . In the case of a 44.1 kHz sample rate, the count 
values allocated with half, whole and wide pulses are, 
respectively, about 36, 71 and 107. 

[0 0012] The count value that is supplied by the counter 14 
is provided to a discriminator 18, a downcounter 22, a 
comparator 26 and a register 30. The output of the 
comparator 2 6 is connected to the load input of the 
downcounter 2 2 and to the write enable input of the register 
30. If the output signal of the comparator 26 is high, the 
count value supplied by the counter 14 is written into the 
register 3 0 and is also loaded into the downcounter, which 
then counts down at a fairly low rate. The rate at which the 
downcounter counts down is selected so that the downcounter 
will not count to 2/3 or less of its initial value in the 
subframe interval corresponding to the lowest sample rate. 
The output of the downcounter is supplied to the comparator 
26 . 

[00013] Let us assume that a first count value 
corresponding to the duration of a whole pulse has been 
loaded into the downcounter 22 (71 in the case of a 44.1 kHz 
sample rate) and a second count value is provided by the 
counter 14. If the second count value were larger than the 
count currently provided by the downcounter, the comparator 
2 6 would provide a high output and the second count value 
would be loaded into the register 3 0 and into the downcounter 
22. If the second count value were smaller, the comparator 
would provide a low output and the second count value would 
not be loaded into either the downcounter 22 or the register 
30. Based on this manner of operation, it will be 
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appreciated that no later than the end of the first subfrarae 
of the AES3 data stream, the count value loaded into the 
downcounter 22 and into the register 3 0 will be the value 
corresponding to the wide pulse (107) During the second 
subfratne, the count provided by the downcounter will never go 
below 72 and accordingly a half or whole pulse will have no 
effect on the register 30. At the end of the second 
subframe, the downcounter will be refreshed to 107 by the 
wide pulse in the preamble of the third subframe. It will 
therefore be seen that the value loaded into the register 3 0 
will be the count value corresponding to the duration of the 
wide pulse of the input data stream. 

[00014] The value loaded into the register 30 is supplied 
to the address input of a lookup table 34 having a 16 bit 
data output- The lower byte (bits 0-7) of the word returned 
by the lookup table in response to the count value of the 
wide pulse corresponds to the duration of the half pulse 
whereas the upper byte (bits 15-8) corresponds to the 
duration of the whole pulse. In the case of the count value 
being 107, the lower byte is decimal 36 and the upper byte is 
decimal 71. 

[00015] The count value stored in the register 30 and the 
upper and lower bytes supplied by the lookup table are 
supplied as reference values to the discriminator 18, which 
compares each count value provided by the counter 14 with the 
three reference values and provides an output indicating 
whether the count value corresponds to a wide, half or whole 
pulse. The discriminator does not require precise 
coincidence between the count value and one of the reference 
values supplied to the discriminator but on the contrary 
defines a window about each reference value. For example, if 
the reference values for half, whole and wide pulses are X, Y 
and Z respectively, the discriminator might establish as the 
window for the half pulse reference value the range from X- 
X/2 to X+X/2, for the whole pulse reference value Y-X/2 to 
Y+X/2 and for the wide pulse reference value, Z-X/2 to Z+X/2 . 

[00016] The discriminator 18 has three outputs HA (half) , 
WH (whole) and WI (wide) . When the discriminator compares a 
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count value provided by the counter 14 with the reference 
values, it asserts a logic high output on the output that 
corresponds to the outcome of the comparison. Accordingly, 
the sequence in which logic high levels are asserted at the 
three outputs of the discriminator corresponds to the 
sequence of half, whole and wide pulses received by the edge 
detector . 

[00017] The three outputs of the discriminator 18 are 
supplied to a state machine 38 which examines the sequence of 
half, whole and wide pulses and identifies the preamble. 
Each of the 24 doublets following the preamble contains the 
binary value of a source data bit and has a logic value 1 or 
0. The state machine 3 8 derives the logic value for each 
source data bit from the outputs provided by the 
discriminator and supplies the 24 data bits for each sample 
value to a 24 bit wide FIFO memory 42. The state machine 38 
also provides a write enable signal for writing to the 
memory. Accordingly, the 24 -bit digital sample values are 
loaded sequentially in to the memory. A downstream processor 
44 generates a read enable signal for reading the digital 
sample values sequentially from the memory. The sample 
values read from the memory are supplied to the downstream 
processor for processing. If the rate at which the processor 
44 reads sample values from the memory 42 does not match the 
rate at which the state machine writes sample values to the 
memory 42, the processor 44 will repeat or drop sample values 
as needed. 

[00018] It will be seen from the foregoing that the 
apparatus shown in the drawings is able to extract the sample 
data from the input AES3 data stream without its being 
necessary to recover a clock and without regard to the sample 
rate of the data stream. 

[00019] It will be appreciated that the invention is not 
restricted to the particular embodiment that has been 
described, and that variations may be made therein without 
departing from the scope of the invention as defined in the 
appended claims and equivalents thereof. For example, 
although a lookup table is used to provide the reference 
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values corresponding to the duration of the half and whole 
pulses, it would alternatively be possible to calculate the 
reference values. Unless the context indicates otherwise^ a 
reference in a claim to the number of instances of an 
element, be it a reference to one instance or more than one 
instance, requires at least the stated number of instances of 
the element but is not intended to exclude from the scope of 
the claim a structure or method having more instances of that 
element than stated. 



